PATENT- OCH

(12)

2000-09-25

1999-05-07

1997-11-06

(19) SE



REGISTRERINGSVERKET

(51) Internationall klass 7 H04Q 11/06 // H04L 12/52

- (45) Patent meddelat
- (41) Ansökan alimänt tiligänglig
- (22) Patentansökan inkom
- (24) Löpdag
- (62) Stamansökans nummer
- (88) Internationall ingivningsdag
- (86) Ingivningsdag för ansökan om europeisk patent
- (63) Deposition av mikroorganism
- (30) Prioritetsuppgifter

(21) Patentansökningsnummer 9704067-9

1997-11-06 Ansökan inkommen som:

svensk patentansökan

Available Cop fullföljd internationell patentansö med nummer

omvandlad europeisk patentansökan med nummer

- (73) PATENTHAVARE Net Insight AB, Ingenjörsvägen 3 117 43 Stockholm SE (72) UPPFINNARE
- Christer Bohm, Stockholm SE, Lars Gauffin, Rönninge SE,
- Lukas Holm, Stockholm SE, Joachim Roos, Nacka SE (74) OMBUD
- AWAPATENT AB
- (54) BENÄMNING Förfarande och anordning för överföring av data mellan bitströmmar i ett tidsmultiplexerat nät
- (56) ANFÖRDA PUBLIKATIONER:

US A 4 809 261 (H04Q 11/06), US A 5 128 929 (H04Q 11/06), US A 4 005 272 (H040 11/06) Journal of hig speed networks, volume 3, No 2, 1994 Christer Bohm et al, "The DTM Gigabbit Network page 109-126, Space communications, volume 7, No 4-6, 1990, W. Berner et al, "Switching Structures for on-board processing", page 405-410, especially paragraph 22

#### (57) SAMMANDRAG:

föreliggande uppfinning hänför sig till ett förfarande och en anordning för överföring av data mellen en första uppsättning bitströmmar (1, 2, 3, 4) och en andra uppsättning bitströmmar (5, 6, 7, 8) hos ett kretskopplac, tidsmultiplexerat nat, varvid var och en av námnda bitströmmar (1, 2, 3, 4, 5, 6, 7, 8) indelas i áterkommande ramar och var och en av nämnda återkommende ramar indelas i tidluckor.

Uppfinningen innefattar att motta nämnda första uppsättning bitströmmar (1, 2, 3, 4); att tillfälligt lagra varje ram av data från varje bitström (1, 2, 3, 4) av nämnda första uppsättning bitströmmar (1, 2, 3, 4); att selektivt läsa, för varje ram av varje bitström (5, 6, 7, 8) av nämnda andra uppsättning bitströmmar (5, 6, 7, 8), data från valda ramar av de för tillfället lagrade ramarna av nämnda första uppsättning bitströmmar (1, 2, 3, 4); och att avge nämnda data, som lästs från nämnda ramar, i ellokerande tidluckor av nämnda andre uppsättning bitströmmar (5, 6, 7, 8).



#### Teknikområde

5

15

20

Föreliggande uppfinning hänför sig till ett förfarande och en anordning för överföring av data mellan en
första uppsättning bitströmmar och en andra uppsättning
bitströmmar hos ett kretskopplat, tidsmultiplexerat nät,
varvid var och en av nämnda bitströmmar indelas i återkommande ramar och var och en av nämnda återkommande
ramar indelas i tidluckor.

## 10 Teknisk bakgrund och känd teknik

Nya typer av kretskopplade kommunikationsnät utveckas idag för överföring av information med utnyttjande av synkrona tidsmultiplexerade bitströmmar, vilka bitströmmar typiskt är indelade i ramar, eller cykler, och vilka ramar i sin tur är indelad i tidluckor.

Ett exemple på ett sådant nät har beskrivits i "The DTM Gigabit Network", Christer Bohm, Per Lindgren, Lars Ramfelt och Peter Sjödin, Journal of High Speed Networks, 3(2):109-126, 1994, och i "Multi-gigabit networking based on DTM", Lars Gauffin, Lars Håkansson och Björn Pehrson, Computer networks and ISDN Systems, 24(2):119-139, April 1992.

Den grundläggande topologin hos ett nät av detta slag är företrädesvis en buss med två enkelriktade multi25 accessfibrer som kopplar samman ett antal noder, där varje nod är anordnad att betjäna en eller flera slutanvändare som är anslutna därtill. Notera att topologin emellertid lika gärna kan vara realiserad med någon annan slags struktur, t.ex. ringstruktur eller stjärnstruktur.

Bandbredden hos varje våglängd på bussen, dvs varje bitström på fiberna, är indelad i ramar av fastlagd storlek, vilka i sin tur är indelade i tidluckor av fastlagd storlek. Antalet tidluckor i en ram beror således av nätets bitfrekvens. Tidluckorna är indelade i två

10

2

grupper, kontrolltidluckor och datatidluckor. Kontroll-tidluckor används för signalering mellan nätets noder för nätets interna drift. Datatidluckorna används för överföring av data mellan de användare som är anslutna till de olika noderna.

Varje nod är anordnad att dynamiskt allokera tidluckor till sina respektive anslutna användare, att användas vid sändning eller mottagning av information till respektive från andra användare. Som ett resultat därav har olika anslutna användare skrivrättighet till olika datatidluckor.

När exempelvis en första användare som är ansluten till en första nod önskar överföra information till en andra användare som är ansluten till en andra nod, kommer den första noden att allokera ett antal datatidluckor inom varje ram för den första användare att sända data i. Den första noden kommer dessutom att sända ett signaleringsmeddelande i en kontrolltidlucka till den andra noden och på så sätt instruera den andra noden att läsa data från de allokerade datatidluckorna och att vidarebefordra sådana data till den andra användaren. De allokerade datatidluckorna sägs bilda en kanal mellan de två användarna.

I ett sådant nät används så kallade växlar, var och en ansluten till en eller flera bitströmmar, eller 25 fibrer, för att överföra data mellan olika bitströmmar. Antag exemplevis att en kanal mellan en första och en andra användare, vilka är anslutna till en första respektive en andra nod på en första respektive en andra fiber, definieras av en första uppsättning tidluckor på en bit-30 ström som utbreder sig på den första fibern och en andra uppsättning tidluckor på en bitström som utbreder sig på den andra fibern. En växel används då för att överföra eller kopiera data från den första uppsättningen tidluckor till den andra uppsättningen tidluckor, eller 35 omvänt.

Kända växlar i synkrona, tidmultiplexerade nät utnyttjar ett styrminne som mappar varje inkommande tidlucka mot en utgående tidlucka. Sådan mappning (eller "avbildning") kan inbegripa både en mappning i tiden, dvs styrning av den följd med vilken data skrivs in i en bitström, och en mappning i rummet, dvs styrning av vilka data som skall till vilken bitström. Exempelvis beskrivs sådana så kallade TST-växlar ("time-space-time switches") i "Data and Computer Communications", fjärde upplagan, av Williams Stallings, Macmillan Publishing Company. Kända växlar uppvisar emellertid begränsningar vad gäller möjligheten att växla tidluckor i rum och tid. Kända växlar uppvisar dessutom begränsningar vad gäller överföringshastighet och överföringskapacitet.

15

20

25

30

10

## Uppfinningens syfte

Ett syfte med uppfinningen är att åstadkomma en växel som erbjuder större frihet vad gäller möjligheterna att växla tidluckor i rum och tid, såsom effektiv entill-flera-växling ("multicasting") av kanaler med olika bandbredd.

Ett annat syfte med uppfinningen är att tillhandahålla en enkel och snabb mekanism för växling mellan flera inkommande och utgående bitströmmar som är godtyckligt fasförskjutna i förhållande till varandra.

Ett annat syfte med uppfinningen är att öka växelns överföringshastighet och kapacitet.

Ett ytterligare syfte med uppfinningen är att tillhandahålla ett skalningsbart växelsystem, varvid mindre växlar enkelt kan integreras till att bilda större växlar.

## Redogörelse för uppfinningen

Enligt en aspekt på uppfinningen uppnås ovan nämnda och andra syften medelst ett förfarande av inledningsvis nämnt slag, innefattande stegen: att motta nämnda första uppsättning bitströmmar; att tillfälligt lagra varje ram

25

30

35

, ,

្តជ

4

av data från varje bitström av nämnda första uppsättning bitströmmar; att selektivt läsa, för varje ram av varje bitström av nämnda andra uppsättning bitströmmar, data från valda ramar av de för tillfället lagrade ramarna av nämnda första uppsättning bitströmmar; och att sända nämnda data, som lästs från nämnda ramar, i allokerade tidluckor av nämnda andra uppsättning bitströmmar.

Enligt en andra aspekt på uppfinningen uppnås ovan nämnda och andra syften medelst en anordning av inledningsvis nämnt slag, innefattande mottagarorgan för 10 mottagning av varje bitström av nämnda första uppsättning bitströmmar; ramminnesorgan för tillfällig lagring av varje ram av data från varje bitström av nämnda första uppsättning bitströmmar; läsorgan för selektiv läsning, för varje ram av varje bitström av nämnda andra uppsätt-15 ning bitströmmar, av data från de för tillfället lagrade ramarna av nämnda första uppsättning bitströmmar; och utmatningsorgan för sändning av nämnda data, som lästs från nämnda ramminnesorgan, i allokerade tidluckor av 20 nämnda andra uppsättning bitströmmar.

I ett exempel på kända växlar är in- och utportar sammankopplade med hjälp av ett delat medium, av vilket det krävs att det kan hantera inportarnas aggregerade växlingskapacitet för att inte skapa blockering, vilket begränsar skalbarheten hos en sådan design.

I ett annat exempel på kända växlar är en inport hos en en-till-en-växel (endast en inkommande bitström och en utgående bitström) försedd med information som anger, för varje tidlucka i den mottagna bitströmmens ram, vart data från denna tidlucka skall sändas, dvs till vilken utgående tidlucka. Om man skulle tänka sig en flerportstillämpning av denna kända lösning, varvid ett flertal inportar, som mottar data från respektive bitströmmar, skall skriva data, baserat på sådan information, till ramminnen hos en eller flera utgående bitströmmar, måste man utveckla åtkomstmekanismer för att fördela skrivrättigheter till nämnda ramminnen och för att säkerställa

35

ς,

att olika inportar inte skriver data samtidig till samma minnesfält.

För att hantera en-till-flera-sändning, dvs för att överföra data från en inkommande bitström till flera utbuffertminnen, ställs dessutom krav på inportarna att tillhandahålla, för varje tidlucka i den mottagna bitströmsramen, information som anger, för varje utport, vilken utgående tidlucka som data skall skrivas in i.

Samma begränsningar gäller för så kallade TST-växlar som använder tidsmappning vid in- och utportarna och rumsmappning däremellan för att tillåta godtycklig kommunikation mellan in- och utportar.

Enligt uppfinningen löses detta problem genom att man vid inportarna inte behöver tillhandahålla information som anger vart data från en mottagen tidlucka skall 15 sändas eller skrivas, utan genom att man istället vid varje utport tillhandahåller information som anger varifrån data för utgående tidluckor skall hämtas eller läsas. De mottagna bitströmmarna, eller snarare varje ram därav, lagras vid växelns inportar i respektive rammin-20 nen, och så kallade tidluckemappningstabeller vid växlens utportar tillhandahåller information om varifrån, dvs från vilket ramminne och vilket datafält därav, data skall hämtas för varje enskild tidlucka i respektive utgående bitström. Data hämtas följaktligen selektivt 25 från de mottagna bitströmmarna för att därefter sändas ut i de utgående bitströmmarna. Varje sekventiell uppslagning i sekventiella rader hos en sådan tidluckemappningstabell ger en respektive ramminnesadress för utläsning av data för den specifika utgående tidluckan. 30

Enligt en utföringsform av uppfinningen innefattar varje ramminne ett flertal datafält som är anordnade att lagra data från respektive tidluckor i följden av tidluckor hos återkommande ramar av den inkommande bitström som hör samman med respektive ramminne.

Växeln är följaktligen företrädesvis indelad på ett sådant sätt att ett respektive ramminne är associerat med

35

. 45

(1)

6

varje inport. Samtliga utportar kan läsa data från varje ramminne oberoende av varandra. En hel växel innefattar följaktligen en uppsättning ramminnen, vilka vart och ett är anordnat i en en-till-flera konfiguration (en inport till flera utportar).

Nämnda ramminnen är företrädesvis realiserade i form av flerportade asynkrona RAM-minnen som möljiggör inskrivning och utläsning oberoende av varandra och utan fassynkronisering.

Genom att använda RAM-minnen med flera läsportar, kan varje utgående bitström, oberoende av andra, hämta sina egna data, vilket företrädesvis sker med utnyttjande av ledningar som är dedikerade enbart för nämnda utgående bitström för åstadkommande av en icke-blockerande drift.

15 Följaktligen föreligger inget behov av inbördes uteslutning eller av komplicerade reservationsmodeller på en
delad resurs. Dessutom kräver konceptet inte någon ökad
kommunikationshastighet i någon del av konstruktionen i
förhållande till den frekvens med vilken varje ledning
20 mottar eller sänder data.

Eftersom ramminnena uppdateras kontinuerligt vid en hög frekvens, kan en realisering som baseras på dynamiska RAM (DRAM) utnyttjas utan något behov av så kallad "memory refresh".

Enligt uppfinningen läser samtlig utportar data från ramminnena oberoende av varandra, och företrädesvis överförs data från ramminnena till utportarna med utnyttjande av ledningar som är dedikerade åt respektive utport.

Uppfinningen uppvisar således väsentliga fördelar 30 vid användning för en-till-flera-sändning (multicasting), dvs överföring av data från en inport till flera utportar.

Enligt en föredragen utföringsform av uppfinningen innefattar växeln organ, exemplevis i form av nämnda tidluckemappningstabeller, för att för var och en av de tidluckor i en ram av varje utgående bitström som är allokerade att motta data från de inkommande bitström-

10

15

7

marna tillhandahålla en respektive identifikation som pekar ut ett associerat datafält hos nämnda ramminnesorgan, vilket datafält tillhandahåller data för den respektive allokerade tidluckan; och organ för selektiv läsning, för tidluckorna i varje ram av var och en av nämnda utgående bitströmmar, av data från nämnda datafält baserat på sådana identifikationer.

Eftersom flera olika tabellrader i flera tidluckemappningstabeller kan peka ut samma ramminne och samma
datafält, föreligger således stöd för en-till-alla
sändning och en-till-flera sändning.

Nämnda organ för tilldelning av en identifikation, såsom en tidluckemappningstabell, innefattar företrädesvis en uppsättning organ som betjänar respektive utgående
bitström, men kan även innefatta ett enda organ som
betjänar samtliga utgående bitströmmar.

En sådan identifikation kan exempelvis vara a) en identifikation som unikt identifierar ett ramminne och en tabellrad därav som tillhandahåller de data som skall sändas i den utgående tidlucka som hör samman med nämnda 20 identifikation, b) en identifikation som anger att skrivrättighet till motsvarande utgående tidlucka inte tillhör den egna växeln och att den utgående tidluckan därför skall lämnas opåverkad, c) en identifikation som anger att ett idle-mönster skall alstras av växeln och sändas i 25 den motsvarande utgående tidluckan och d) en identifikation som anger att data som mottagits från en en annan växel skall sändas i nämnda motsvarande tidlucka, Utpekandet av varífrån data skall hämtas för varje enskild utgående tidlucka tillhandahåller således flera nya 30 möjligheter att växla data. Den sistnämnda av de fyra ovan angivna typerna av identifikationer gör det exempelvis möjligt att på ett enkelt sätt koppla samman flera växlar till att bilda en större växel, och att därigenom öka möjligheterna till att växla data utan att väsentligt 35 komplicera en möjlig realiserig.

15

20

25

30

35

(ab)

8

Var och en av ramminnena har företrädesvis kapacitet att lagra tre hela sekventiella ramar av den respektive inkommande bitströmmen i separata minnesområden, vilka nedan även benämnds sidor eller kolumner, av varje ramminne. Utnyttjandet av tre sidor avser att säkerställa konsistent växling, dvs att säkerställa att den selektiva läsningen från en ram eller sida inte äger rum före det att inskrivningen av den specifika ramen eller sidan är avklarad. Enligt den föredragna utföringsformen behövs en sida för att möjliggöra om-mappning av tidluckor i tidsdomänen, en annan behövs för parallel lagring av dubbelbuffringsslag, och den tredje sidan behövs för att hantera förekommande fasskillnad mellan den inport som skriver in i nämnda ramminne och de utportar som läser från ramminnet, en skillnad som är begränsad till en sida som följd av den generella synkroniseringen i ett nät av ovan nämnda slag.

Var och en av in- och utportarna styrs av en respektive ramsynkroniseringssignal, vilken stegar fram interna pekare för identifiering av den för tillfället valda ramminnessidan, dvs antingen vilken sida som utnyttjas för inskrivning eller vilken sida som utnyttjas för läsning. Tidluckorna hos en inkommande bitström skrivs in i sekventiell följd, medan utgående tidluckor hämtas från nämnda ramminnen med utnyttande av direktuppslagning ("random access") bland tabellraderna hos den sida som för tillfället utpekas för selektiv läsning.

Tidluckor och ramar klockas således med utnyttjande av klock- och ramsynkroniseringssignaler som är lokala för varje port. Ett underliggande antagande är att ramsynkroniseringsignalerna aldrig uppvisar en fasskillnad mellan en inkommande bitström och en utgående bitström som växer sig större än en ram, dvs det förekommer ingen ackumulerad fasskillnad (fasdrift).

En inkommande bitströms ramsynkroniseringssignal styr med fördel en skrivtidluckeräknare som för varje mottagen tidlucka stegar fram en skrivpekare, som anger ■18. VEC2001 10:13

5

10

30

en tabellrad i respektive ramminne, till nästa tabellrad. (Vid mottagning av ramsynkroniseringssignalen återställs företrädesvis skrivtidluckeräknaren för att ånyo börja på den lägsta tidluckepositionen i nästa ram).

Den inkc mande bitströmmens ramsynkronisering styr företrädesvis även ett block för selektering av sida för skrivning, vilket pekar ut en sida hos respektive ramminne och därmed iordningställer en av de tre ramsidorna hos ramminnet för skrivning. (Vid mottagning av ramsynkroniseringssignalen stegas pekaren fram till nästa ramminnessida, och efter sista sidan hos ett ramminne stegas pekaren fram till ramminnets första sida).

Ramsynkroniseringssignalen för en utgående bitström styr med fördel en räknare för utgående tidluckor, vilken för varje utgående tidlucka stegar fram en läspekare i 15 nämnda tidluckemappningstabell för härledning av information avseende varifrån data för den aktuella utgående tidluckan skall hämtas. (Vid mottagning av ramsynkroniseringssignalen återställs företrädesvis räknaren för att ånyo börja på den lägsta tidluckepositionen i nästa 20 utgående ram). Den utgående bitströmmens ramsynkroniseringssignal styr även med fördel ett block för selektering av sida för läsning, vilket pekar ut de ramminnessidor som för tillfället kan utnyttjas för selektiv läsning. Vid mottagning av ramsynkroniseringssignalen 25 väljs nästa ramminnessida, och efter sista sidan hos ett ramminne stegas pekaren fram till ramminnets första sida.

En fördel med uppfinningen är således att styrning av arbetet vid varje port hos växeln åstadkommes baserat på en ramsynkronisering som är lokal för varje respektive port, vilket således eliminerar behovet av att tillhandahålla komplicerade korsrelaterade synkroniseringsmekanismer mellan olika in- och utportar.

Enligt en ytterligare utföringsform av uppfinningen 35 styrs nämnda selektering av sida för läsning även av en mekanism för så kallad sid-offset och bypass, vilken aktiveras på tidluckebasis av tidluckemappningstabellen.

10

15

25

30

35

## 513 518

10

Bypass-moden tillhandahåller valet att läsa en ram före den ram som pekas ut av den faktiska läspekaren, vilket minskar fördröjningen genom växeln men sätter begränsningar på tidluckeallokering för säkerställande av att ingen accesskonflikt eller inkonsistenthet uppkommer vid om-mappning i tidsdomänen.

Enligt en ytterligare utföringsform av uppfinningen tillhandahålls en mekanism för automatisk uppdatering av tidluckemappningstabellerna, dvs för samtidig uppdatering av fler än en tidlucketabell och fler än en tabellrad därav med bevarad konsistenthet.

Ovan nämnda och andra aspekter på och särdrag hos uppfinningen kommer att framgå med tydlighet av de exemplifierande utföringsformer av uppfinningen som beskrivs nedan med hänvisning till de bifogade ritningarna.

#### Kortfattad beskrivning av ritningarna

Exemplifierande utföringsformer av uppfinningen 20 kommer nu att beskrivas med hänvisning till de bifogade ritningarna, på vilka:

fig. 1 schematiskt visar en växel i ett kretskopplat, tidsmultiplexerat nät;

fig. 2 schematiskt visar strukturen på en av bitströmmarna i fig. 1;

fig. 3 schematiskt visar en växel som växlar tidluckedata i tid och rum;

fig. 4 schematiskt visar en utföringsform av en växel enligt föreliggande uppfinning;

fig. 5 schematiskt visar en utföringsform av en tidluckemappningstabell av det slag som visas i fig. 4;

fig. 6 schematiskt visar en mekanism för selektering av ramsida, att användas vid varje in- och utport;

fig. 7a och 7b schematiskt visar sid-offset vid tillstånden full om-mappning respektive by-pass;

fig. 8 schematiskt visar ett ramminne och multipla utportar hos en växel enligt uppfinningen;

15

20

25

## 513 518

11

fig. 9, 10a och 10b schematiskt visar en mekansism för uppdatering av de tidluckemappningstabeller som visas i fig. 5 och fig. 8.

# 5 Detaljerad beskrivning av föredragna utföringsformer

I fig. 1 visas en växel, eller nod, SW i ett kretskopplat, synkront, tidsmultiplexerat nät. Växeln SW har fyra inportar, vilka är anslutna till respektive bitströmmar 1-4, och fyra utportar, vilka är anslutna till respektive bitströmmar 5-8. I fig 1 utbreder sig varje bitström på en respektive optisk fiber. Utöver tidsmultiplexering kan även våglängdsmultiplexering användas för att öka nätets kapacitet genom att flera bitströmmar bärs av olika våglängder på en och samma fiber. Var och en av bitströmmarna 1-8 används av en eller fler noder N1-N14 för transport av data till/från andra noder. Olika bitströmmar kan användas för kommunikation i olika riktningar, varvid kommunikationsriktningen illustreras i fig. 1 med pilar vid de optiska fibrernas slutpunkter. Såsom kommer att beskrivas ytterligare nedan är kommunikationen på varje optisk fiber 1-8 synkron och tidsmultiplexerad.

Såsom visas i Fig. 1 kan bitströmmarna vid växelns inportar vara terminerade vid växeln, såsom är fallet med bitströmmarna 2-4, eller kan de fortsätta förbi växeln till att nå noder belägna nedströms växeln, såsom är fallet med bitströmmen 1. Bitströmmarna vid växelns utportar kan härröra från växeln, såsom är fallet med bitströmmarna 5-7, eller kan häröra från andra noder belägna upströms växeln, såsom är fallet med bitströmmen 8.

I Fig. 1 är varje nod N1-N14 anordnad att betjäna en eller flera användare (ej visade) genom att tillhandahålla access till bitströmmarna 1-8. En nod kan dessutom vara ansluten till fler än en bitström, såsom är fallet med noderna N2 och N13. När exempelvis en användare som är ansluten till nod N3 önskar sända information till en användare som är ansluten till nod N12, kommer noderna N3 och N12 att etablera en kretskopplad kommunikationskanal

10

15

20

25

## 513 518

12

på bitströmmar 1 och 7. Nod N3 kommer därefter att överföra data från den sändande användaren till bitströmmen 1, växeln SW kommer att växla nämnda data från bitströmmen 1 till bitströmmen 7 och nod N12 kommer i sin tur att överföra dessa data från bitströmmen 7 till den mottagande användaren. Det inses att användarna kan vara varje slags elektronisk utrustning som behöver tillgång till nätet, såsom datorer, arbetsstationer, skrivare, servrar, faxapparater, telefoner, TV-apparater, radiomottagare, och liknande.

Strukturen på de tidsmultiplexerade bitströmmar som används i fig. 1 kommer nu att beskrivas med hänvisning till fig. 2. Varje bitström är indelad i ramar, eller cykler, av given längd, exempelvis 125 µs. Varje ram är i sin tur indelad i tidluckor av given storlek, exempelvis 64 bitar. Antalet tidluckor i varje ram beror således på nätets bitfrekvens. Det antal tidluckor 1-6 som visas i en ram i fig 2 är naturligtvis enbart illustrativt. Det verkliga antalet tidluckor i en ram kommer normalt att vara mycket större än så.

Tidluckorna är generellt indelade i två grupper, kontrolltidluckor C och datatidluckor D. Kontrolltidluckorna C används för styrsignalering mellan nätets noder, dvs för överföring av meddelanden mellan noderna för nätets interna drift, såsom för kanaluppsättning, tidluckeallokering, osv. Datatidluckorna D används för överföring av användardata mellan användare som är anslutna till nämnda noder.

Utöver nämnda kontrolltidluckor och datatidluckor innefattar varje cykel en eller flera synkroniseringstidluckor S som används för att synkronisera varje nods arbete gentemot varje ram. För att säkerställa att antalet tidluckor i en ram inte kommer att överlappa en efterföljande ram, följer dessutom ett skyddsband G efter den sista luckan vid slutet av varje ram. Såsom indikeras i fig 2 upprepas ramen kontinuerligt.

15

20

25

30

ŗ.,

## 513 518

13

Varje nod har tillgång till åtminstone en kontrolltidlucka C och till ett dynamiskt antal datatidluckor D på den bitström som används av noden. Varje nod använder sin kontrolltidlucka för att kommunicera med andra noder i nätet. Antalet datatidluckor D som allokeras till respektive nod beror av den överföringskapacitet som efterfrågas av de slutanvändare som betjänas av respektive nod. Om en specifik nods användare kräver en stor överföringskapacitet, kommer noden att allokera fler datatidluckor för detta ändamål. Om å andra sidan användarna vid en viss nod endast behöver en liten överföringskapacitet, kan noden begränsa antalet därtill allokerade datatidluckor. Även antalet kontrolltidluckor som allokerats till en nod kan ökas eller minskas beroende på nodens signaleringsbehov. Allokeringen av såväl kontrolltidluckor som datatidluckor till olika noder kan således anpassas dynamiskt allteftersom nätetbelastningen förändras. Det inses att det i denna typ av kretskoppling inte förekommer någon adressinformation inbäddad i dataströmmen.

I en grundläggande utföringsform hanterar växeln enligt uppfinningen kontrolltidluckor C på samma sätt som den hanterar datatidluckor D. Vad växeln angår tillhandahåller såväl datatidluckor som kontrolltidluckor tidluckedata som skall växlas i enlighet med instruktioner som lagras i växeln. En nodstyrenhet som styr växelns arbete kan emellertid vara anordnad att använda en eller flera kontrolltidluckor och datatidluckor för att motta och sända information avseende kanaluppsättning, kanalmodifiering och kanalnedtagning, och att styra växelns växlingsinstruktioner baserat därpå, såsom kommer att beskrivas nedan.

Enligt uppfinning kan växeln i fig. 1 överföra data från vilken inport som helst till samtliga utportar parallellt vid varje given tidpunkt (så kallad ickeblockerande växling). Att överföra information till flera utportar från samma inport motsvarar multicasting eller

18. DEC2001 10:15

10

15

30

35

## 513 518

14

broadcasting. En grundläggande egenskap hos en växel enligt uppfinningen är att den kan utföra tidsmappning i samma operation som den växlar data från ingång till utgång, dvs den genomför växling i såväl tid som rum. Tidsväxlingen möjliggör införlivande av tidluckedata från en viss tidlucka i en inkommande ram till en annan tidlucka i en utgående ram.

I fig. 3 visas en växel SW, som kan vara den som visas i fig. 1, anordnad att växla tidluckedata från tidluckor A0-An, B0-Bn av första bitströmmar A och B i tid och rum till tidluckor av andra bitströmmar C och D. Såsom visas i fig. 3 kan data i en tidlucka i en utgående ram av bitström C vara hämtad från vilken som av bitströmmar A och B och från vilken som av tidluckorna dărav. Förekomsten av A0 i de båda utgående bitsrömmarnas C och D ramar motsvarar multicasting av tidluckan AO till både bitström C och bitström D, men till olika tidluckor i respektive utgående ramar.

En exemplifierande utföringsform av en växel i enlighet med uppfinningen kommer nu att beskrivas med 20 hänvisning till fig. 4. I fig. 4 mottar växeln SW, som kan vara den som används i växelnoden i fig. 1, tidluckedata från fyra inkommande bitströmmar 1-4 och överför den mottagna tidluckedata till fyra utgående bitströmmar 5-8. Växeln SW innefattar följaktligen fyra inportar 21-24 och 25 fyra utportar 65-68 som ger access till respektive bitströmmar.

Varje inport 21-24 är anordnad att skriva varje ram som mottas från den respektive inkommande bitströmmen till ett respektive ramminne (rambuffert) 31-34. Varje ramminne 31-34 har kapacitet att lagre tre sekventiella ramar av respektive bitström i tre motsvarande minnesområden 31a-31c, 32a-32c, 33a-33c, 34a-34c, nedan även benämnda "sidor", där varje minnesområde har kapacitet att lagra en ram. Exempelvis kommer ramminnnet 31, som tillfälligt lagrar varje ram av data som mottas som bitström l via inporten 21, att sekventiellt lagra en

25

30

## 513 518

15

första ram i minnesområdet 31a, nästa (andra) ram i minnesområdet 31b, och den efterföljande (tredje) ramen i minnesområdet 31c. Den därpå följande (fjärde) ramen kommer därefter att lagras återigen med utnyttjande av minnesområdet 31a, varvid den där tidigare lagrade första ramen skrivs över. Notera även att tidluckedata från en rams tidluckor skrivs in sekventiellt i respektive tidluckedatafält av respektive minnesområde, dvs ett datafält för varje tidlucka.

Vidare är fyra selekteringsenheter 45-48, vilka, 10 såsom illustreras i utföringsfomer nedan, kan vara realiserade i form av multiplexorer eller tri-statebussar, anordnade att selektera tidluckedata att sändas till respektive utgående bitström 5-8 genom att fastställa, för varje utgående tidlucka, från vilket ram-15 minne, och från vilket minnesområde därav, samt från vilket tidluckedatafält därav (dvs. bland för tillfället lagrade tidluckedata från samtliga fyra inkommande bitströmmar 1-4) som tidluckedata skall hämtas eller släppas fram till respektive utgående bitström. Varje selekte-20 ringsenhet 45-48 är således ansluten till samtliga fyra ramminnen 31-34 för hämtning av tidluckedata därifrån.

För att veta vilket ramminne, vilket minnesområde därav, och vilket datafält eller vilken tabellrad därav som skall användas för en specifik utgående tidlucka, har varje selekteringsenhet 45-48 tillgång till en respektive tidluckemappningstabell 55-58, vilken kommer att beskrivas mer detaljerat nedan med hänvisning till fig. 5.

Varje tidluckemappningstabell 55-58 tillhandahåller, för varje tidlucka i den respektive utgående bitströmmens ram och vid en respektive tabellrad, ett fält (av en kolumn 55a-58a) som pekar ut ett ramminne och ett fält (av en kolumn 55b-58b) som pekar ut den tabellrad eller det fält därav som skall användas vid hämtning av data för den aktuella utgående tidluckan. Tidluckemappningstabellernas 55-58 tabellrader accessas företrädesvis i samma sekventiella ordning som den för tidluckorna i den motsvarande

10

15

20

## 513 518

16

utgående ramen, och varje tidluckemappningstabell stegas igenom en gång för varje ram av den tillhörande utgående bitströmmen.

När tidluckedata exempelvis skall hämtas till den första tidluckan i varje ram av bitström 5, kommer selekteringsenheten 45 att gå till tidluckemappningstabellens 55 första tabellrad, mer specifikt till det första datafältet i kolumnen 55a och till det första datafältet i kolumnen 55b, för att härleda information som pekar ut från vilket av de fyra ramminnena och från vilken tabellrad eller vilket fält därav som tidluckedata skall hämtas. Selekteringsenheten 45 kommer även att styra valet av vilket minnesområde eller sida i varje ramminne 31-34 som skall användas vid hämtningen av tidluckedata för den ram som för tillfället skrivs ut som bitström 5, såsom kommer att beskrivas mer detaljerat nedan. Selekteringsenheten kommer följaktligen att hämta tidluckedata enligt en given utmatningföljd för samtliga tidluckor som skall motta data i den utgående bitströmmen. Växeln SW kommer enbart att sända tidluckedata i de tidluckor hos den utgående bitströmmen som är allokerade för detta ändamål.

En utföringsform av en tidluckemappningstabell av det slag som visas i fig. 4 (och i fig. 9 som kommer att beskrivs nedan) kommer nu att beskrivas med hänvisning till fig. 5. Tidluckemappningstabellen (SMT - "Slot 25 Mapping Table") är en tabell i vilken de allokerade kanalerna är definierade. Såsom visas i fig. 4 finns företrädesvis en tidluckemappningstabell för varje utgående bitström. Den tidluckemappningstabell som visas i fig. 5, vilken exempelvis kan vara tidluckemappnings-30 tabellen 55 i fig. 4, är en ram djup och innehåller tre logiska minnesområden eller kolumner, varvid varje kolumn innefattar ett antal fält som motsvarar antalet tidluckor i den utgående ramen, så att varje tabellrad, innefattande ett fält från vardera kolumn, unikt identifierar en 35 inkommande bitström och en tidlucka därav. Varje fält i den första kolumnen (55a i fig. 4) definierar en inkom-

17

mande bitström (eller ett ingående ramminne), och varje fält i den andra kolumnen (55b i fig. 4) definierar en tidlucka därav (eller en tabellrad därav), och fälten i den tredje kolumnen (som endasat visas i fig. 5) definierar en sid-offset som kommer att beskrivas mer detaljerat nedan med hänvisning till fig. 6, 7a och 7b. Tidluckemappningstabellen definierar således tidluckeschemat i den utgående ramen, och inbegriper växling i såväl tid som rum.

Tidluckemappningstabellen stegas igenom uppifrån och ner en gång för varje utgående ram, för att definiera mappningen av varje utgående tidlucka därav, och utsignalen från tidluckemappningstabellen pekar direkt ut associerad tidluckedata från ramminnena. Således behövs endast en enkel räknemekanism, såsom kommer att beskrivas nedan, för alstring av sekventiella adresser till tidluckemappningstabellen, vilken översätter dessa till direktuppslagningsaddresser som används för datahämtning från ramminnena.

20 Utgående från den exemplifierande tidluckemappningstabell som visas i fig. 5 kommer den första tidluckan i varje utgående ram som styrs av denna tidluckemappningstabell att innehålla data från den femtonde tidluckan i varje ram av den tredje bitströmmen, medan den andra utgående tidluckan inte kommer att förses med data från 25 någon inkommande bitström, vilket skulle kunna resultera i sändning av en så kallad idle-bitgrupp om skrivrättighet till den andra utgående tidluckan är allokerad att användas av växeln. Vidare framgår att den tredje utgående tidluckan skall hämtas från den 3988:e tidluckan i 30 varje ram av den andra inkommande bitströmmen, och så vidare.

En sid- eller minnesområdesselekteringsmekanism att användas vid varje inport och varje utport kommer nu att beskrivas med hänvisning till fig. 6, 7a och 7b. Såväl inskrivningen av tidluckedata i ramminnena, som den selektiva utläsningen vid utmatning av tidluckedata med

18

utnyttjande av tidluckemappningstabellerna, styrs var och en av separata och oberoende ramsynkroniseringssignaler, vilka härleds från eller definieras för de respektive bitströmmarna, vilket sammantaget gör att växeln består av N (antalet inportar) plus M (antalet utportar) klockdomäner. Ramsynkroniseringsssignalerna används för att stega fram respektive skriv- eller läsperkare som selekterar sidor, dvs minnesområden, i respektive ramminnen.

För varje inport och varje utport används ett respektive pekarblock, som visas i fig. 6, vilket klockas av 10 respektive ramsynkroniseringssignaler SYNK. Perkarblocket är anordnat att peka ut vilket minnesområde, dvs vilken sida, av respektive ramminne som skall användas för skrivning eller selektiv utläsning. I varje pekarblock 100 stegar en sjävgående räknare fram en sid-adress, i 15 modulo-3-form, på varje mottagning av respektive ramsynkroniseringssignal. Varje pekarblock tillhandahåller således sekventiellt sid-adress 0, 1, 2, 0, 1, 2, 0, 1, ..., och så vidare. Varje pekarblock 100 mottar dessutom en sid-offset-signal som har ett värde som adderas (också 20 i modulo-3-form) till räknarens värde för att ge en resulterande ramsidoselekteringssignal, såsom kommer att besrivas ytterligare nedan med hänvisning till fig. 7a och 7b.

Det sekventiella utpekandet av minnesområden hos ett ramminne för inskrivning av ramar av respektive bitström, såsom beskrivits ovan med hänvisning till fig. 4, kommer att åtföljas av ett motsvarade sekventiellt utpekande av minnesområden hos ramminnet för selektiv utläsning av tidluckedata därifrån. För varje ramminne kommmer det att finnas en skrivpekare (som hör samman med inskrivningen av respektive inkommande bitström) och M läspekare (som var och en hör samman med den selektiva utläsningen för respektive utgående bitström), där M är antalet utgående bitströmmar.

Det är viktigt att utpekandet av minnesområden eller sidor för sekventiell inskrivning och utpekandet av sidor

35

## 513 518

19

för selektiv utläsning utförs på ett sådant sätt att buffertkonsistenthet bevaras i syfte att undvika att tidluckedata från en ram läses ut innan inskrivningen därav är avklarad. Sådan konsistenthet uppnås genom att tre minnesområden utnyttjas i varje ramminne, vilket gör det möjligt att alltid hålla ett minsta avstånd på en halv ram mellan inskrivningen och utläsningen av tidluckedata, såsom kommer att beskrivas ytterligare med hänvisning till fig. 7a och 7b.

I pekarblocket 100 i fig. 6, när det används vid en utport för den selektiva utläsningen av ramar, modifieras den självgående räknarens sid-adress av tillförandet av en sid-offset-signal som mottas från tidluckemappningstabellen, såsom nämnts ovan med hänvisning till fig. 5.

Sid-offset-signalen härleds från tidluckemappningstabellens sid-offset-fält och modifierar pekarblockets adress genom att addera en offset därtill, också i modulo-3-form, till att bilda en modifierad sid-adress. Sid-offset-signalen anges således per tidlucka och beror

av fasskillnad ("skew") mellan den inkommande och den utgående bitströmmens ramar samt av kriterier för accessbegränsningar. Accessbegränsningar är restriktioner som läggs på tidsommappningen i syfte att reducera fördröjningen genom växeln på bekostnad av att möjligheten till ommappning i tiden begränsas. Ramsynkroniseringens

fasskillnad anges här i intervallet -1 < fasskillnad < 1, uttryckt som andel av en hel ram.

Fig. 7a visar tilldelningen av sid-offset under så kallad full tidsmappning, dvs då inga accessbegränsningar föreligger, vilket även benämns normal mod. Det antas i fig. 7a att sid-offset hos pekarblocket för inskrivning av en inkommande bitström är satt till 2, vilket innebär att inskrivningen kommer att gå över till sida 0 (=2+1 i modulo-3) efter mottagningen av nästa ramsynkroniseringssignal hos den inkommande bitströmmen. Den selektiva utläsningen från ramminnet kan då accessa minnesområden med utnyttjande av antingen 0 eller 1 som sid-offset

15

20

25

30

35

### 513 518

20

beroende på ramsynkroniseringens fasskillnad. Vid förhållanden då en negativ fasskillnad föreligger, dvs då den utgående bitströmmens ramsynkroniseringsignal uppträder före den inkommande bitströmmens, sätts sid-offset till 0 (det alternativ som pilen längst ner till vänster i fig. 7a visar). Den selektiva utläsningen kommer då alltid att hinna hoppa till nästa minnesområde och kommer inte att fångas in av att skrivpekaren senare förflyttar sig till ett nytt minnesområde. Vid förhållanden då en positiv fasskillnad föreligger, dvs då den utgående bitströmmens ramsynkroniseringsignal anländer efter den inkommande bitströmmens, sätts sid-offset till 1 (det alternativ som pilen längst ner till höger i fig. 7a visar). Detta innebär att en buffertmarginal om en sida (en ram) tillförs mellan inskrivning och utläsning. Dessa tilldelningsregler säkerställer att inskrivningen som uppdaterar en sidan kommer att vara avklarad när läspekaren stegar in till denna sida. Det innebär dessutom att skrivpekaren inte kommer att hinna runt och ikapp genom att stega in på den sida som läses innan läspekaren har fortsatt till nästa sida.

Fig. 7b visar tilldelningen av sid-offset i en så kallad bypass-mod, vilken aktiveras av data från det tredje fältet hos tidluckemappningstabellen i fig. 5. I normal mod, såsom diskuterats ovan med hänvisning till fig. 7a, medger växeln full tidsommappning av data från första inkommande tidlucka till sista utgående tidlucka, och vice versa, men detta kräver buffring av inte enbart en skrivsida och en lässida utan också av en extra ram (den tredje sidan) som säkerställer konsistenthet, vilket således tillför en fördröjning genom växeln. I bypass-mod kan fördröjningen genom växeln reduceras en ram för en eller flera tidluckor på bekostnad av vissa resktriktioner för om-mappning, såsom diskuteras nedan. I den bypass-mod som visas i fig. 7b är läspekrens sid-offset för normal mod från fig 7a tillfälligt uppstegad ett steg för enskilda en eller flera tidluckor av en ram, vilket

10

15

20

25

30

## 513 518

21

följaktligen gör det möjligt för skriv- och läspekarna att tillfälligt använda samma sida, såsom illustreras i fig 7b i form av de alternativa läspekarpilarnas försjutning ett steg till höger i jämförelse med fig. 7a.

Denna bypassmod kan endast tillåtas under förutsättning att den selektiva läsningen inte läser före den sekventiella skrivningen, vilket säkerställs om ingen utgående tidlucka, hos en utgående bitström, mottar data från en inkommande tidlucka, hos en inkommande bitström, som har ett högre tidluckenummer. Utgående tidlucka #9 kan således använda bypassmod för att reducera fördröjningen genom växeln när den läser data från en inkommande tidlucka #3, men utgående tidlucka #3 får inte använda bypassmod vid utläsning av data från en inkommande tidlucka #9.

Denna förutsättning för bypass kan i själva verket relaxeras om den faktiska fasskillnaden tas i beaktande. För enkelhets skull antas nu att fasskillnaden uttrycks i antal tidluckor. När fasskillnaden är positiv, dvs när den inkommande bitströmmens ramsynkroniseringssignal uppträder före den utgående bitströmmens ramsynkroniseringssignal, kan fasskillnaden utnyttjas för att tillåta utläsning av tidluckedata för utgående tidluckor från inkommande tidluckor med högre sekvensnummer, så länge växeln inte refererar längre fram än fasskillnaden. Med negativ fasskillnad, dvs när den utgående bitströmmens ramsynkroniseringssignal uppträder före den utgående bitströmmens ramsynkroniseringssignal, har man i den normala moden redan tillfört en marginal om en ram, vilket innebär att nästan full bypass-ommappning tillåts om fasskillnaden är nästan noll men negativ. När å andra sidan fasskillnaden är nästan minus en ram, tillåts ingen bypass frammåt. Detta sammanfattas i tabell I nedan.

10

## 513 518

22

#### Tabell I

| MOD     | FAS-<br>SKILLNAD | FÖRDRÖJNING         | MAPPNINGS-       |
|---------|------------------|---------------------|------------------|
|         | BILLINAD         |                     | BEGRÄNSNINGAR    |
| Normal  | Positiv          | 1 ram + fasskillnad | Inga             |
| Normal  | Negativ          | 2 ramar -           | inga             |
|         |                  | ABS(fasskillnad)    |                  |
| Bypass  | Positiv          | Fasskillnad         | Inkommande lucka |
|         |                  |                     | - Utgående lucka |
|         |                  |                     | < Fasskillnad    |
| Bypass  | Negativ          | 1 ram -             | Inkommande lucka |
|         |                  | ABS(fasskillnad)    | - Utgående lucka |
| <u></u> |                  |                     | < Fasskillnad    |

De ramsynkroniserings- och sidselekteringsmekanismer som beskrivits ovan med hänvisning till fig. 6, 7a och 7b utnyttjas med fördel i den utföringsform som beskrivits oven med hänvisning till fig. 4, även om sådana element ej explicit visas där, och de utnyttjas även i den utföringsform som kommer att beskrivas nedan med hänvisning till fig. 8.

En ytterligare utföringsform av en växel i enlighet med föreliggande uppfinning, vilken inbegriper de särdrag som beskrivits ovan med hänvisning till fig. 4, 5, 6, 7a och 7b, kommer nu att beskrivas med hänvisning till fig. 8, varvid växeln SW är anordnad att växla data mellan N 15 inkommande bitströmmar och M utgående bitströmmar. Eftersom överföring av data från en av de N inkommande bitströmmarna till de M utgående bitströmmarna går till på samma sätt som överföringen från de övriga inkommande bitströmmarna, och eftersom den selektiva utläsningen 20 från de N inkommande ramminnena till en av de M utgående bitströmmarna sker på samma sätt som den selektiva utläsningen till de övriga utgående bitströmmarna, såsom illustreras i fig. 4, kommer endast de element som i första hand hör samman med en inkommande bitström och en 25

■18. DEC2001 10:19

5

10

15

20

25

30

35

## 513 518

23

utgående bitström att visas i fig. 8, och beskrivningn av växeln i fig 8, kommer att begränsas i enlighet därmed.

I fig. 8 är en inport 210 på växeln SW anordnad att motta en inkommande bitström och att mata den till en demultiplexor 220. En ramsynkroniseringsenhet hos inporten härleder ramsynkroniseringssignalen från den inkommande bitströmmen och synkroniserar, baserat därpå, en skrivtidluckeräknare 240 och en enhet 250 för selektering av skrivsida. Dessutom är en klockenhet hos inporten 210 anordnad att mata en signal, som uppträder i takt med tidluckefrekvensen, till skrivtidluckeräknaren 240. Enheten 250 för selektering av skrivsida är anordnad att styra demultiplexorn 220, i takt med ramsynkroniseringssignalens frekvensen, till att sekventiellt i modulo-3form skriva in ramarna av den inkommande bitströmmen i tre minnesområden, eller sidor, 300a, 300b och 300c av ett ramminne 300 för nämnda inkommande bitström.

Under det att enheten 250 för selektering av skrivsida och demultiplexorn 220 styr vilken sida av ramminnet som en specifik ram av den inkommande bitströmmen skall skrivas in i, kommer skrivtidluckeräknaren att styra vilken tabellrad av den aktuella sidan som tidluckedata från varje specifik tidlucka av ramen skall skrivas in i. Den beskrivna uppsättningen komponenter kommer att återfinnas vid varje inport hos växeln SW.

Det utmatande delen av växel, vilken visas ì den nedre delen av fig. 8, innefattar, för varje utgående bitström, en första uppsättning om M multiplexorer 310, en andra multiplexor 320, en utport 330, en tidluckeräknare 350, en tidluckemappningstabell 370, en enhet 380 för selektering av lässida, och en idle-generator 390.

Porten 330 härleder en ramsynkroniseringssignal, antingen från den utgående bitströmmen (om en synkronisering redan existerar på nämnda bitström, varvid bitströmmen härrör från en nod som är belägen upströms växeln), eller genom intern alstring av en ramsynkroniseringssignal (om växeln är den utgående bitströmmens start18. DEC 2001 10:19 AWAPATENT\_+4684409550 NR. 6852 S.

#### 513 518

24

punkt).

5

10

15

20

25

30

35

Ramsynkroniseringssignalen matas till att synkronisera tidluckeräknaren 350 och enheten 380 för selektering av lässida. Utporten härleder även en klocksignal som uppträder i enlighet med tidluckefrekvensen och som matas till tidluckeräknaren 350. Tidluckeräknaren adresserar sekventiellt tidluckemappningstabellens 370 tabellrader, och stegar igenom tidluckemappningstabellen en gång varje ram. För en specifik utgående tidlucka av den utgående bitströmmen kommer tidluckeräknaren således att peka ut en motsvarande tabellrad hos tidluckemappningstabellen 370. Tidluckemappningstabellen kommer då att tillhandahålla tre signaler som baseras på data från denna tabellrad, såsom har beskrívits ovan; en signal som pekar ut den inkommande bitström från vilken tidluckedata för den aktuella utgående tidluckan skall hämtas, vilken signal sänds till den andra multiplexorn 320, en signal som pekar ut vilken tidlucka i den återkommande sekvensen av tidluckor inom en ram av den inkommande bitströmmen som tidluckedata skall hämtas ifrån, vilken signal sänds till samtiga N ramminnen, och en signal som pekar ut vilken sid-offset som används, vilken signal sänds till enheten 380 för selektering av lässida, såsom har diskuterats ovan med hänvisning till fig. 5, 7a, och 7b.

Det tidluckenummer, exempelvis tidluckenummer i, som lästs ut från tidluckemappningstabllen, för den för tillfället behandlade utgående tidluckan, matas från tidluckemappningstabellen 370 till vart och ett av de N ramminnena (endast ett visas fig. 8) med utnyttjande av direktuppslagning, vilket föranleder utläsning av den i:e tabellraden från var och en av de tre sidorna hos vart och ett av de n ramminnena (vilket totalt innebär en utläsning från 3 x n datafält). Det tre utläsningarna från varje ramminne matas till nämnda första uppsättning multiplexorer 310, där var och en av multiplexorerna 310 är anordnad att motta tidluckedata från tre sidor av det tillhörande ramminnet. Enheten 380 för selektering av

15

20

## 513 518

25

lässida är därefter anordnad att styra nämnda första uppsättning multiplexorer, i takt med ramsynkroniseringssignalen, för att avgöra vilka tidluckedata, motsvarande respektive sidor, som vid varje givet tillfälle skall matas vidare av multiplexorerna 310, varvid hänsyn tas till förekomsten av varje slags sid-offset- eller bypassinstruktioner, såsom de mottas från tidluckemappningstabellen. Var och en av multiplexorerna 310 kommer således att tillhandahålla tidluckedata från ett av fälten hos respektive ramminne, vilket totalt innebär N utläsningar av tidluckedata som sänds till den andra multiplexorn 320. I den andra multiplexorn avgörs vilken av dessa N utläsningar, dvs från vilken bitström, som skall sändas till den utgående bitströmmen, i enlighet med vad som pekas ut av den bitströmsselekterande signalen från tidluckemappningstabellen 370. Tidluckemappningstabellen 370 och enheten 380 för selektering av lässida utnyttjar således nämnda första och andra multiplexorer 310, 320 för att hämta tidluckedata från ett specifikt valt fält av ett specifikt valt minne av nämnda ramminnen.

Såsom visas i fig. 8 matas även ett idle-mönster och en kaskaderingssignal till den andra multiplexorn. Tidluckemappningstabellen 370 kan följdaktligen, för varje specifik tidlucka av den utgående bitströmmen, instruera 25 den andra multiplexorn 320 att sända ett idle-mönster från idle-generatorn 390, exempelvis för den andra, ickeallokerade tidluckan enligt tidluckemappningstabellen i fig. 5. Notera emellertid att det faktum att en tidlucka 30 inte är allokerad inte nödvändigtvis innebär att ett idle-mönster skall sändas istället, eftersom tidluckan mycket väl kan vara allokerad att användas av andra noder som är anslutna till den utgående bitströmmen (speciellt om växeln inte är bitströmmens startpunkt). För att möjliggöra sammankoppling av flera växlar av detta slag 35 till en större växel, kan kaskaderingsingången användas. En utgående bitström från en annan växel ansluts då till

15

20

25

30

35

### 513 518

26

den andra multiplexorns kaskaderingsingång, vilket gör det möjligt att växla data från denna andra växel till den utgående bitströmmen från växeln SW, dock fortrafande i enlighet med vad som anges av tidluckemappningstabellen 370. Kaskaderingsmöjligheten innebär att man kan skapa större switchar utgående från små växlar, exempelvis kan fyra 4×4-växlar användas för att bygga en full 8×8-växel

En konfigurationssignal från en nodstyrenhet som styr uppdatering av tidluckemappningstabellen matas till denna, såsom illustreras av den pil som betecknas Konfig i fig. 8 och såsom kommer att beskrivas ytterligare nedan med hänvisning till fig. 9, 10a och 10b.

Den beskrivna uppsättningen komponenter 310-390 återfinns vid var och en av växelns M utportar, vilket ger ett total antal om N×M första mutliplexorer (310) och ett totalt antal om M andra multiplexorer (320).

Såsom har beskrivits ovan är en första nivåns multiplexor anordnad vid utgången från vart och ett av ramminnena för att välja data från de tre ramsidorna därav. Resultatet matas därefter till en andra nivåns mutliplexor som väljer en specifik bitström (inport). Detta tillvägagångssätt uppfyller två syften: a) det visar att data överförs på ledningar som är privata för var och en av utportarna, vilket gör att man undviker att utnyttja ett delat, gemensamt medium; och b) det illustrerar de distinkta paramterar som styr selekteringen.

I beaktande av de hårdvarukostnader som hör samman med utnyttjande av flera breda bussar, kan emellertid även utnyttjande av andra byggblock än multiplexorer övervägas. Enligt en alternativ utföringsform används en tri-state-buss eller en pre-charged-buss istället för multiplexorerna i syfte att uppnå samma ändamål som multiplexorerna men med ett mycket bättre utnyttjande av yta. Om man använder direktåtkomstminnesmoduler (RAM) för att implementera ramminnena, finns ofta tri-state-utmatning redan inkluderat däri. Det bör noteras att en sådan utföringsform inte kräver några ytterligare medel

15

20

25

30

## 513 518

27

för inbörders uteslutning. Vid varje tidpunkt är den källa som har rätt att driva bussen unikt specificerad. I en sådan utföringsform alstaras en signal för aktivering av en drivenhet från ett avkodarblock som har inporten (såsom den läses ut från tidluckemappningstabellen) och ramsidopekaren (0..2) som insignal.

På liknande sätt kan den demultiplexor som matar ramar av den inkomande bitströmmen till respektive ramsidor av ramminnet också ersättas med en bus som matar data till samtliga tre sidor, varvid en skrivaktiveringssignal selekterar vilken ramsida som skrivs till.

Ett förfarande för uppdatering av tidluckemappningstabeller hos en växel i enlighet med uppfinningen kommer nu att beskrivas med hänvisning till fig. 9, 10a och 10b. När de kanaler eller tidluckor som skall växlas mellan olika bitströmmar ändras som följd av omallokering av resurser, uppdateras växelns tidluckemappningstabeller antingen med utnyttjande av en central enhet inne i växeln eller via ett externt gränssnitt kopplat till en dator som styr växelns arbete, såsom en central enhet eller dator som ofta benämns nodstyrenhet (NC - "Node Controller"). I fallet då en extern dator utnyttjas, är det externa gränssnittet åtskilt från växelns portar, och den bandbredd som utnyttjas för att uppdatera tidluckemappningstabellerna är generellt avsevärt lägre än bandbredden på växlens portar.

Ett problem som föreligger vid uppdatering av tidluckemappningstabeller vid flera utgångar med olika ramfaser är att bibehålla ramkonsistenthet, vilket exempelvis krävs vid hantering av multicast-kanaler. Ett fördelaktigt sätt att lösa detta problem, som självfallet inte
är begränsat till uppdatering av multicast-kanaler på
multipla utportar, visas i fig 9, 10a och 10b, där fig. 9
visar tre uppdateringstabeller som adresseras av nodstyrenheten, fig. 10a visar ett flödesschema över nodstyrenhetens uppdateringsförfarande, vilket benämns global
uppdatering, och fig 10b visar ett flödesschema över

15

20

25

30

35

## 513 518

28

uppdateringsförfarandet hos var och en av tidluckemappningstabellerna, vilket benämns lokal uppdatering.

När ett uppdateringsförfarande inleds, i steg S10 i fig. 10a, kommer nodstyrenheten att adressera uppdateringstabeller 410, 420 och 430 som visas i fig. 9, vilka exempelvis kan vara anordnade i styrenheten eller i växeln i kommunikation med styrenheten. I steg S20 uppdaterar nodstyrenheten tabeller 430 (en tabell 430 för varje tidluckemappningstabell) innefattande en uppsättning fält som pekar ut vilka utgående tidluckor, i följden av utgående tidluckor, som skall uppdateras i respektive tidluckemappningstabell och vilka motsvarande data som skall ersätta gammal data vid respektive fält av nämnda tidluckemappningstabell. Efter att på detta sätt ha angivit alla aktuella uppdateringar för alla aktuella tidluckemappningstabeller, vilket konstatera i ett steg S30, kommer nodstyrenheten att instruera tidluckemappningstabellerna att uppdatera sitt innehåll genom nodstyrenheten sätter en uppsättning flaggor, en för varje tidluckemappningstabell, till ett (1) i en tabell 410 (tabellen 410 i fig. 9 representerar indikationer till fyra tidluckemappningstabeller). Den förser även en ramselekteringstabell 420 med information som anger vid vilken ram, i modulo-3-ordning, som tidluckemappningstabellerna skall uppdatera sitt innehåll.

På motsvarande sätt kommer varje tidluckemappningstabell at vid starten av varje ram, vilket indikeras av mottagandet av en ramsynkroniseringssignal i steg B10, undersöka huruvida tidluckemappningstabellens flagga i tabell 410 är satt, i steg B20, för att fastställa huruvida tidluckemappningstabellen skall uppdateras. Om så inte är fallet, dvs om den flagga som hör till tidluckemappningstabellen är satt till noll (0), kommer tidluckemappningstabellen är satt till noll (0), kommer tidluckemappningstabellen att gå vidare till att genomföra selektiv utläsning av tidluckedata från ramminnena i steg B30, B40 och B50 på det generella sätt som beskrivits ovan. Om emellertid flaggan indikerar att uppdatering begårs, dvs

30

35

٦

## 513 518

29

om den flagga som hör till tidluckemappningstabellen är satt till ett (1), kommer tidluckemappningstabellen att undersöka ramselekteringstabellen 420 i steg B60 för att avgöra huruvida tidluckemappningstabellen skall uppdateras vid starten av den aktella ramen eller vid 5 starten av en senare ram. Om uppdateringen inte skall äga rum förrän vid en senare ram, fortsätter tidluckemappningstabellen till att genomföra selektiv utläsning av tidluckedata från ramminnena på det generella sätt som 10 beskrivits ovan. Om emellertid ramselekteringstabellen 420 indikerar att uppdatering skall ske under den aktuella ramen, kommer tidluckemappningstabellen att börja processa tidluckor på vanligt sätt, men för varje tidlucketabellrad kommer den att se efter, i steg B70, i 15 sin uppdateringstabell 430 huruvida tabellraden för den aktuella tidluckan skall updateras, och, om så är fallet, uppdatera tabellraden med den information som tillhandahålls i uppdateringstabellen 430 före det att den selektiva utläsningen genomförs. När hela ramen har stegats igenom på detta lätt, kommer tidluckemappningstabellen 20 att återställa sin uppdateringsflagga i tabell 410, och på så vis informera nodstyrenheten om att uppdateringen är avklarad.

På motsvarande sätt kommer nodstyrenheten att kontinuerligt undersöka tabellen 410, i steg S50, för se efter huruvida samtliga tidluckemappningstabeller har återställt sina flaggor. När så har skett, dvs när samtliga flaggor i tabellen 410 har återställts till noll (0), avslutas uppdateringsförfarandet i steg S60.

Detta uppdateringsförfarande är utformat i syfte att reducera antalet återsynkroniserade signaler, dvs signaler från andra klockdomäner synkroniserade med varandra. Den selekterade synkroniseringen kan baseras på en sätt/återställ-vippa för varje utport. Varje återställning styrs då av det lokala uppdateringsförfarandet.

Istället för att uppdatera enskilda tidluckor kan nodstyrenheten enligt en alternativ utföringsform till-

10

#### 513 518

30

handahålla data för en hel ny ram, varvid nodstyrenheten helt enkelt intruerar tidluckemappningstabellerna att byta hela ramen av mappningsdata. Emellertid kan blotta antalet tidluckor i en ram medföra att denna utförings-form blir långt mer tidskrävande jämfört med alternativet att endats uppdatera en delmängd av tidluckor.

Även om uppfinningen har beskrivits ovan med hänvisning till exemplifierande utföringsformer därav, kan
olika förändringar, modifieringar och kombinationer
därav, såsom inses av fackmän inom teknikområdet, realiseras inom ramen för uppfinningen skyddsomfång, vilket
definieras av de bifogade patentkraven.

20

## 513 518

31

#### PATENTKRAV

- 1. Förfarande för överföring av data mellan en första uppsättning bitströmmar och en andra uppsättning bitströmmar hos ett kretskopplat tidsmultiplexerat nät, varvid var och en av nämnda bitströmmar indelas i återkommande ramar och var och en av nämnda återkommande ramar indelas i tidluckor, vilket förfarande innefattar stegen:
- att motta nämnda första uppsättning bitströmmar; att tillfälligt lagra tre sekventiella ramar, av varje bitström av nämnda första uppsättning bitströmmar, i respektive minnesområden;
- att selektivt läsa, för varje ram av varje bitström 15 av nämnda andra uppsättning bitströmmar, data från de för tillfället lagrade ramarna av nämnda första uppsättning bitströmmar; och

att avge nämnda data, som lästs från nämnda ramar, i allokerade tidluckor hos nämnda andra uppsättning bitströmmar.

- 2. Förfarande enligt krav 1, varvid nämnda lagringssteg innefattar steget att lagra nämnda ramar i ett flertal datafält hos ett ramminne, vilka datafält är anordnade att lagra data från respektive tidluckor i följden av tidluckor i återkommande ramar för varje bitström av nämnda första uppsättning bitströmmar.
- 3. Förfarande enligt krav 1 eller 2, varvid nämnda läsningssteg innefattar stegen: att för var och en av de tidluckor i ramar av nämnda andra uppsättning bitströmmar som är allokerade att motta data från nämnda första uppsättning bitströmmar tillhandahålla en respektive identifikation på ett därtill associerat datafält hos nämnda ramminne, vilket datafält tillhandahåller data att sändas ut i respektive tidlucka; och att selektivt läsa, för tidluckorna i varje ram av varje bitström av nämnda andra

#### 513 518

32

uppsättning bitströmmar, data från nämnda datafält baserat på nämnda identifikationer.

- 4. Förfarande enligt något föregående krav, innefattande stegen: att motta en ytterligare bitström;
  att för en tidlucka i en ram av åtminstone en bitström av nämnda andra uppsättning bitströmmar, vilken
  tidlucka är allokerad att motta data från nämnda ytterligare bitström, tillhandahålla en identifikation som är
  relaterad till nämnda ytterligare bitström för hämtning
  av data därifrån; och att selektivt läsa, för nämnda
  tidlucka hos nämnda åtminstone en bitström av nämnda
  andra uppsättning bitströmmar, data från nämnda
  ytterligare bitström baserat på nämnda identifikation.
- 5. Förfarande enligt krav 3 eller 4, innefattande att tillhandahålla en uppsättning identifikationsuppdateringar och därtill associerad ramselekteringsinformation avseende den ram under vilken införandet av nämnda identifikationsuppdateringar skall äga rum, och att uppdatera nämnda identifikationer med nämnda uppsättning identifikationsuppdateringar under den ram som anges av nämnda associerade ramselekteringsinformation.
- 6. Förfarande enligt något krav 3, 4 eller 5, varvid nämnda steg att tillhandahålla en identifikation innefattar att för varje tidlucka i en ram av varje bitström av nämnda andra uppsättning bitströmmar tillhandahålla en identifikation som anger huruvida den respektive tidluckan hos nämnda andra uppsättning bitströmmar skall motta data från någon av nämnda första uppsättning bitströmmar och, om så är fallet, från vilket respektive datafält som nämnda data skall hämtas.
- 7. Förfarande enligt något föregående krav, innefattande steget att för varje bitström av nämnda första uppsättning bitströmmar detektera en ramsynkroniserings-

33

signal och att, baserat därpå, synkronisera nämnda till-fälliga lagring av ramar från varje bitström av nämnda första uppsättning bitströmmar.

- 8. Förfarande enligt något föregående krav, innefattande steget att fastställa en ramsynkroniseringssignal för varje bitström av nämnda andra uppsättning
  bitströmmar och att, baserat därpå, synkronisera nämnda
  utläsning av data och sändningen därav i nämnda andra
  uppsättning bitströmmar.
- Förfarande enligt krav 1, innefattande steget att för var och en av nämnda första uppsättning bitströmmar ange, vid varje given tidpunkt, vilket av nämnda minnes-områden som för tillfället används för inskrivning av ramar för lagring.
- 10. Förfarande enligt krav 1 eller 9, innefattande steget att ange, vid varje given tidpunkt, vilka av
  20 nämnda ramminnesområden som för tillfället används för selektiv läsning av data för nämnda andra uppsättning bitströmmar.
- 11. Förfarande enligt något föregående krav, varvid
  25 kanaler på nämnda bitströmmar definieras av respektive
  uppsättningar tidluckor i varje ram av respektive bitström, vilka tidluckor allokeras dynamiskt baserat på
  dynamiskt varierande kapacitetskrav från nätets noder.
- 12. Anordning för överföring av data mellan en första uppsättning bitströmmar och en andra uppsättning bitströmmar i ett kretskopplat, tidsmultiplexerat nät, varvid var och en av nämnda bitströmmar indelas i återkommande ramar och var och en av nämnda återkommande ramar indelas i tidluckor, innefattande:

mottagarorgan (21-24; 210) för mottagning av nämnda första uppsättning bitströmmar;

34

ramminnesorgan (31-34; 300) innefattande tre minnesområden (31a-31c; 300a-300c) för varje bitström av nämnda
första uppsättning bitströmmar, vilka tre minnesområden
är anordnade att tillfälligt lagra tre sekventiella ramar
av respektive bitström av nämnda första uppsättning bitströmmar;

läsorgan (45-48, 55-58; 310, 320, 370) för selektiv läsning, för varje ram av varje bitström av nämnda andra uppsättning bitströmmar, av data från valda ramar av de för tillfället lagrade ramarna av nämnda första uppsättning bitströmmar; och

organ (5-8; 330) för sändning av nämnda data, som lästs från nämnda ramminnesorgan, i allokerade tidluckor hos nämnda andra uppsättning bitströmmar.

15

20

25

30

10

5

- 13. Anordning enligt krav 12, varvid nämnda ramminnesorgan innefattar ett flertal datafält som är anordnade att lagra data från respektive tidluckor i följden
  av tidluckor i återkommande ramar av varje bitström av
  nämnda första uppsättning bitströmmar.
- 14. Anordning enligt krav 12 eller 13, varvid nämnda läsorgan innefattar: organ (55-58; 370; Fig. 5) for att för var och en av de tidluckor i en ram av var och en av nämnda andra uppsättning bitströmmar som är allokerade att motta data från nämnda första uppsättning bitströmmar tillhandahålla en respektive identifikation på ett associerad datafält hos nämnda ramlagringsorgan, vilket datafält tillhandahåller data för den respektive allokerade tidluckan; och organ (45, 48; 310, 320, 380) för selektiv läsning, för tidluckorna i varje ram av var och en av nämnda andra uppsättning bitströmmar, av data från nämnda datafält baserat på nämnda identifikationer.
- 15. Anordning enligt något av kraven 12-14, innefattande: mottagningsorgan (320) för mottagning av en ytterligare bitström; organ (55-58; 370; Fig. 5) för att

35

för en tidlucka i en ram av åtminstone en bitström av nämnda andra uppsättning bitströmmar, vilken tidlucka är allokerad att motta data från nämnda ytterligare bitström, tillhandahålla en identifikation som är relaterad till nämnda ytterligare bitström för hämtning av data därifrån; och organ (320) för selektiv läsning, för nämnda tidlucka hos nämnda åtminstone en bitström av nämnda andra uppsättning bitströmmar, av data från nämnda ytterligare bitström baserat på nämnda identifikation.

10

15

1

5

16. Anordning enligt krav 14 eller 15, innefattande minnesorgan (430) för lagring av en uppsättning identifikationsuppdateringar och för lagring av associerad ramselekteringsinformation (420) avseende den ram under vilken införande av nämnda identifikationsuppdateringar skall äga rum, och organ (410) för uppdatering av nämnda identifikationer med nämnda uppsättning identifikationsuppdateringar under den ram som anges av nämnda associerad ramselekteringsinformation.

20

35

17. Anordning enligt något av kraven 14-16, varvid nämnda organ för tillhandahållande av en identifikation är anordnade att för varje tidlucka i en ram av varje bitström av nämnda andra uppsättning bitströmmar tillhandahålla en identifikation som anger huruvida den respektive tidluckan hos nämnda andra uppsättning bitströmmar skall motta data från någon av nämnda första uppsättning bitströmmar och, om så är fallet, från vilket datafält, hos nämnda ramminnesorgan, som nämnda data skall hämtas.

18. Anordning enligt något av kraven 12-17, innefattande ramsynkroniseringsorgan (210) för detektering av en ramsynkroniseringssignal för var och en av nämnda första uppsättning bitströmmar och för att, baserat därpå, synkronisera den tillfälliga lagringen av ramar,

## 513 518

36

från respektive var och en av nämnda första uppsättning bitströmmar, i nämnda ramminnesorgan.

- 19. Anordning enligt något av kraven 12-18, inne5 fattande ramsynkroniseringsorgan (330) för bestämning av
  en ramsynkroniseringssignal för var och en av nämnda
  andra uppsättning bitströmmar och för synkronisering,
  baserat därpå, av den selektiva läsningen av data från
  nämnda ramminnesorgan och utsändingen därav i nämnda
  andra uppsättning bitstömmar.
- 20. Anordning enligt krav 12, varvid nämnda ramminnesorgan innefattar pekarorgan (100; 250) som anger,
  vid varje given tidpunkt, vilka minnesområden av nämnda
  ramminnesorgan som för tillfället används för inskrivning
  av ramar av nämnda första uppsättning bitströmmar i
  nämnda ramminnesorgan.
- 21. Anordning enligt krav 12 eller 20, varvid nämnda organ för läsning innefattar pekarorgan (100; 380) som anger, vid varje given tidpunkt, vilka minnesområden, av nämnda ramminnesorgan, som för tillfället används för den selektiva utläsningen av data för nämnda andra uppsättning bitströmmar.

22. Anordning enligt något av kraven 12-21, varvid kanaler på nämnda bitströmmar definieras av respektive uppsättningar tidluckor i varje ram av respektive bitström, vilka tidluckor allokeras dynamiskt baserat på

30 dynamiskt varierande kapacitetskrav från nätets noder.



FIG. 1



FIG. 2



FIG. 3

ê

| Tidlucka i<br>utgående ran |   | Från<br>tidlucka | Sid-<br>offset |
|----------------------------|---|------------------|----------------|
| 0                          | 3 | 15               | 0              |
| 1                          | - | -                | _              |
| 2                          | 2 | 3988             | 1              |
| 3                          | 1 | 3                | 2              |
|                            |   |                  |                |
|                            |   |                  |                |
| n                          | 2 | 1501             | 1              |

FIG. 5





FIG. 6



FIG. 7a

FIG. 7b



FIG. 8

6/7

| SMT | Updatera |          |
|-----|----------|----------|
| 1   | 1        |          |
| 2   | 1        | <b>←</b> |
| 3   | 1        |          |
| 4   | 1        | 410      |



| Tidlucka | Ny data |     |
|----------|---------|-----|
| 2        | 257     |     |
| 3        | 196     | -   |
| 4        | -       | 430 |
|          |         | j   |

FIG. 9

)



# This Page is Inserted by IFW Indexing and Scanning Operations and is not part of the Official Record

#### **BEST AVAILABLE IMAGES**

Defective images within this document are accurate representations of the original documents submitted by the applicant.

Defects in the images include but are not limited to the items checked:

| BLACK BORDERS |
| IMAGE CUT OFF AT TOP, BOTTOM OR SIDES |
| FADED TEXT OR DRAWING |
| BLURRED OR ILLEGIBLE TEXT OR DRAWING |
| SKEWED/SLANTED IMAGES |
| COLOR OR BLACK AND WHITE PHOTOGRAPHS |
| GRAY SCALE DOCUMENTS |
| LINES OR MARKS ON ORIGINAL DOCUMENT |
| REFERENCE(S) OR EXHIBIT(S) SUBMITTED ARE POOR QUALITY

## IMAGES ARE BEST AVAILABLE COPY.

OTHER:

As rescanning these documents will not correct the image problems checked, please do not report these problems to the IFW Image Problem Mailbox.

THIS PAGE BLANK (USPTO)